

FIG. 1



FIG. 2



FIG. 3



**FIG. 4A**



FIG. 4B



**FIG. 4C**

| LVa ENCODING |     |        |     |     |          |                  |                  |    |    |     |     |
|--------------|-----|--------|-----|-----|----------|------------------|------------------|----|----|-----|-----|
| 31           | 30  | 29     | 28  | 27  | 26       | 25               | 24               | 23 | 22 | 21  | 20  |
| GROUP        | S/P | Ctr1op | E/D | UAF | InstrCnt | PORT<br>PRIORITY | PORT<br>PRIORITY | SU | LU | ALU | MAU |

454

**FIG. 4D**

| LVb1 ENCODING |     |        |     |     |          |                  |                  |    |    |     |     |
|---------------|-----|--------|-----|-----|----------|------------------|------------------|----|----|-----|-----|
| 31            | 30  | 29     | 28  | 27  | 26       | 25               | 24               | 23 | 22 | 21  | 20  |
| GROUP         | S/P | Ctr1op | E/D | UAF | InstrCnt | PORT<br>PRIORITY | PORT<br>PRIORITY | SU | LU | ALU | MAU |

455

456

| LVb2 ENCODING    |    |    |    |    |    |    |    |    |    |    |    |
|------------------|----|----|----|----|----|----|----|----|----|----|----|
| 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 |
| PORT<br>PRIORITY |    |    |    |    |    |    |    |    |    |    |    |

457

460

**FIG. 4E**

| XVa ENCODING |     |        |    |     |     |     |                  |    |    |     |     |
|--------------|-----|--------|----|-----|-----|-----|------------------|----|----|-----|-----|
| 31           | 30  | 29     | 28 | 27  | 26  | 25  | 24               | 23 | 22 | 21  | 20  |
| GROUP        | S/P | Ctr1op | VX | UAF | RF1 | CE2 | PORT<br>PRIORITY | SU | LU | ALU | MAU |

464

465

7/12

*FIG. 4F*

| LV PARAMETER ENCODING |    |     |        |                  |               |    |    |
|-----------------------|----|-----|--------|------------------|---------------|----|----|
| GROUP                 |    | S/P | CtrlOp | OPCODE EXTENSION | PORT PRIORITY |    |    |
| 31                    | 30 | 29  | 28     | 27               | 26            | 25 | 24 |
| 23                    | 22 | 21  | 20     | 19               | 18            | 17 | 16 |
| 15                    | 14 | 13  | 12     | 11               | 10            | 9  | 8  |
| 7                     | 6  | 5   | 4      | 3                | 2             | 1  | 0  |

475                          470

*FIG. 5*

|   | STORE                   | LOAD                    | ALU                     | MAU                      | DSU                    |
|---|-------------------------|-------------------------|-------------------------|--------------------------|------------------------|
| 1 | Sd.s.w<br>r1,temp       |                         | CmpGT.s.w r3,r4         | sub.sm.w r5,r3,<br>r4    | shr.sd.sw r2,r2,<br>r7 |
| 2 | T.lii.s.w r0, a0+,<br>1 | T.sub.sa.w r4,r6,<br>r5 | F.addi.sm.w r5,r3,<br>0 | T.shl.sd.ld r0,r0,<br>r4 |                        |
| 3 | ld.s.w r2, temp         | F.sub.sa.w r4,r4,<br>r3 | sub.sm.w r7,r6,<br>r3   | shl.sd.ld r0,r0,<br>r5   |                        |

501 ~~~~~ 502 ~~~~~ 503 ~~~~~

500

FIG. 6



FIG. 7

```

702 { start_0_0:
      lim.s.w. A0, COEFF
      lim.s.w. A1, DATA
      lim.s.w. A2, OUTPUT

      lii.s.d R10, A0+,0           ! Load 4 taps in R10/R11
      xor.pa.1d R0, r0, r0          ! set R0/R1 = 0

    704 { lv.p.v0, 0, 5, d=, f=     ! Load VIM Location 0 with 5 instructions
          lii.s.h0 R0,A1+,1           ! Load halfword from memory Data into R0.H0
          shli.sd.1d R0,r0,16          ! Shift Left R0/R1 1-halfword

          sum2p.sm.4sh R2, r0, r10    ! Mpy 4 halfword (data) x 4 taps (results summed in R2&R3)
          add.sa.lw R4, r2, r3          ! Add to halfsums R2/R3 togther to R4
          sii.s.w R4, A2+, 1           ! Store R4 word to output area

    706 { lim.s.w R16, 1f           ! set up outer loop
          eploopi0 12, 1f             ! Loop (D-T)times = 16-4 = 32
          sspr.s.w r16, IEPOR1         ! reset the loop start address

    708 { !start pipeline
          xv.s v0,0,e=ld,f=
          xv.s v0,0,e=ldm,f=
          xv.s v0,0,e=ldm,f=
          xv.s v0,0,e=ldma,f=

    710 { 1:                         ! loop
          xv.s v0,0,e=lmdas,f=

        !shut down pipeline
        xv.s v0,0,e=mdas,f=
        xv.s v0,0,e=mdas,f=
        xv.s v0,0,e=mdas,f=
        xv.p v0,0,e=mas,f=
        xv.p v0,0,e=as,f=
        xv.p v0,0,e=as,f=
        xv.p v0,0,e=s,f=

```

*FIG. 8*



FIG. 9



FIG. 10

